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Introduzione 


Dopo ore e ore passate in solitudine 
assieme al proprio computer, può 
capitare di dimenticarsi che anche lui, 
in fondo, ... è umano. Come tutti gli 
uomini ha malanni e acciacchi vari. 
Le sue malattie? Fatta la necessaria 
trasposizione uomo-macchina, le 
artrosi (tasti), miopia (video), sordità 
(registratore, microdrive), tachicardia 
(chip). 

La cura? Una sola: prevenzione. 
Alcuni preziosi suggerimenti su come 
trattarlo, poi possono migliorare e di 
molto, la vita. 

Ogni tanto, infine, un buon 

check up ... 


Inconvenienti e 
manutenzione 


Nel corso degli anni i 
micro e i personal 
computer sono diventati 
estremamente affidabili, 
soprattutto grazie alla 
costante riduzione del 
numero di componenti 
elettronici che ne 
costituiscono le varie 
parti. L'affidabilità di un 
dispositivo elettronico 
(ed un elaboratore non 
sfugge certamente a 
questa regola) è infatti 
tanto maggiore quanto 
minore è la quantità di 
pezzi che lo 
compongono. In 
confronto ai loro 
predecessori i computer 
moderni sono quindi 
meno soggetti a guasti e 
più resistenti. 


Tuttavia, come d'altra 
parte in qualsiasi 
macchina costruita 
dall'uomo, anche nei 
calcolatori (e relative 
periferiche) si possono 
talvolta riscontrare difetti 
e malfunzionamenti, 
pregiudicando così 
l'affidabilità dell'intero 
sistema. 

In genere, i guasti più 
comuni si localizzano 
nelle parti del computer 
prevalentemente 
soggette ad usura 
meccanica; per esempio: 
tastiera, spinotti di 
alimentazione o di 
connessione, stampante 
e drive. 

Tali inconvenienti (a 
parte casi particolari e 
straordinari) fanno 
comunque parte del 
normale ciclo di vita 
della macchina: proprio 
come un'automobile può 
richiedere di tanto in 
tanto un’aggiustatina alle 
gomme o ai freni, anche 
per un computer è del 
tutto normale che si 
presenti la necessità di 
effettuare qualche 
manutenzione. 

Oggi cercheremo quindi, 
attraverso un'analisi 
delle varie parti che 
costituiscono il tuo 
elaboratore, di 
esaminare le principali e 
più comuni cause di 
possibile cattivo 
funzionamento, 


suggerendone - quando 
possibile - le soluzioni 
più corrette ed adeguate 
da applicare per 
eliminarle. 

La prima e più 
importante 
raccomandazione è 
comunque quella di 
leggere innanzitutto (e 
con attenzione) i manuali 
di utilizzo di tutti i 
dispositivi connessi al 
calcolatore: molte volte 
può infatti accadere di 
commettere un errore 
per scarsa conoscenza 
del funzionamento di un 
certo apparecchio. In 
tutti i manuali vengono 
inoltre forniti preziosi 
consigli ed informazioni 
sulle procedure di 
connessione, gestione e 
funzionamento delle 
varie unità. Spesso pochi 
minuti dedicati alla 
lettura dei manuali 
possono evitare 
parecchi giorni di attesa 
(oltre al costo in denaro) 
per le eventuali 
riparazioni conseguenti 
al non aver rispettato le 
corrette procedure 
operative. 


La tastiera posta troppo in alto 
o troppo in basso costringe 
l'operatore ad una posizione 
scorretta e innaturale. 


La tastiera devono poter assicurare. 
; . . Si è soliti indicare la 

La tastiera è ovviamente durata della tastiera con 

una delle parti il numero di battute 


dell’elaboratore più 
sollecitata durante l’uso; 
per questa ragione, da 
sempre, i costruttori di 
computer dedicano 
particolare attenzione 
alla durata minima (0 
vita) che i vari tasti 
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mediamente usufruibili 
prima di incappare in un 
qualsiasi 
malfunzionamento. Le 
moderne tastiere 
assicurano vite medie 
dell'ordine di milioni di 
battute, corrispondenti 
ad anni di uso normale 
dei vari tasti. 

Gli inconvenienti che 
possono capitare a un 
generico tasto sono 
principalmente due: 
rottura o allentamento 
della molla di ritorno o 
cattivo funzionamento 
dell’interruttore 
corrispondente al tasto 
stesso. Entrambi sono 
facilmente identificabili 


ed eliminabili con la 
semplice sostituzione del 
pezzo difettoso. 

La rottura della molla è 
certamente meno grave 
di quella dell’interruttore 
(è infatti sufficiente 
sollevare il tasto e 
sostituire la molla, 
mentre per cambiare 
l'interruttore si deve 
ricorrere all'uso del 
saldatore), tuttavia, sia in 
un caso che nell'altro, il 
guasto è riparabile con 
facilità e velocità. 

Un nemico della tastiera 
(e in genere di tutte le 
parti elettroniche) è 
inoltre costituito dalla 
polvere, che 
accumulandosi, può 
causare falsi contatti; per 
questo è buona norma 
coprire il calcolatore 
quando non è in 
funzione. 


Il computer 


Tutte le parti componenti 
il computer vero e 
proprio sono dispositivi 
elettronici del tipo “a 
stato solido”. Ciò 
significa che non vi sono 
parti meccaniche o 
elettromeccaniche in 
movimento, tranne 
l'eventuale interruttore di 
accensione e 
spegnimento. La 
conseguenza più ovvia 


ed immediata di questo 
fatto è che in pratica non 
viene richiesta alcuna 
manutenzione. 

Purché nessuno “metta 
le mani” all'interno del 
computer, i circuiti 
integrati, che in larga 
parte compongono 
l'elaboratore, possono 
funzionare (con le debite 
eccezioni) 
tranquillamente per mesi 
e mesi. 

I nemici principali delle 
varie parti circuitali sono 
facilmente identificabili: 
polvere, urti e liquidi. Per 
quanto riguarda la 
polvere vale il discor 
fatto prima: è bene — 
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coprire il computer 
quando non lo si utilizza; 
la polvere potrebbe 
infatti (oltre a favorire i 
falsi contatti) impedire il 
normale scambio 
termico tra l’ambiente 


» 
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esterno e il computer 
provocando 
surriscaldamenti (o 
addirittura bruciature) 
dei circuiti. 

Particolari attenzioni 
vanno inoltre dedicate 
ad eventuali urti e 
vibrazioni. Un computer 
ben costruito è 
abbastanza protetto in 
questo senso e tollera 
senza problemi 
spostamenti e trasporti, 
comprese le vibrazioni 
del bagagliaio di un'auto; 
bisogna comunque fare 
attenzione a non 
esagerare con gli 
sballottamenti poiché, a 
lungo andare, 
potrebbero insorgere 


problemi, dovuti magari 
all’allentamento di 
qualche vite o di 
qualche circuito interno. 
Un discorso a parte 
meritano invece i liquidi. 
Versato su un circuito 
elettrico un liquido gli è 
in ogni caso fatale; 
occorre quindi evitare di 
appoggiare bicchieri o 
bottiglie sopra qualsiasi 
dispositivo elettronico. Il 
pericolo è inoltre 
duplice: primo, 
qualunque liquido 
versato accidentalmente 
provocherà un corto 
circuito all’interno 
dell’elaboratore, con 
conseguenze 
imprevedibili, ma 
sicuramente disastrose. 
Secondo, può insorgere 
un rischio per 
l'incolumità delle 
persone che si 
dovessero trovare nelle 
vicinanze. Molto meglio 
bere in un’altra stanza! 
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Il televisore 
o il monitor 


La manutenzione 
necessaria per 
conservare nel tempo 
l'efficienza e la qualità di 
un televisore o di un 
monitor è veramente 
minima e può essere 
riassunta in poche 
parole: tenerlo pulito e 
regolato correttamente. 
Anche nel caso dello 
schermo video si 
possono comunque 
considerare alcune 
elementari precauzioni. 
Primo: evitare - come al 
solito - l'accumulo di 
polvere. Secondo: 
posizionare l'unità in 
maniera che possa 
esservi un certo 
ricambio d’aria (questa 
regola è fondamentale). 
Terzo: non lasciare 
troppo a lungo la stessa 
immagine sullo schermo; 
può infatti accadere che 
i fosfori presenti sul retro 
dello stesso si 
schiariscano, 
imprimendo in 
permanenza quella 
immagine sullo schermo. 
Questo inconveniente è 
comunque molto limitato 
nei cinescopi moderni. 
Anche per l’unità video - 
in caso di mancato 
funzionamento - vale 
quanto detto a proposito 
del computer vero e 
proprio: non tentare 
assolutamente di 
effettuare riparazioni 
senza avere le 


opportune conoscenze 
teoriche e pratiche. E 
molto più facile per un 
inesperto peggiorare le 
cose invece di 
migliorarle. Inoltre - 
anche con la spina di 
alimentazione staccata 
dalla presa - all’interno 
del monitor o del 
televisore esistono delle 
parti sottoposte in 
permanenza ad 
un'elevata tensione e il 
cui contatto può risultare 
pericoloso per le 
persone. L'unica cosa da 
fare è controllare 
l'integrità del fusibile 
eventualmente inserito 
come protezione 
dell’unità e provvedere - 
nel caso fosse 
danneggiato - alla sua 
sostituzione. 


Il microdrive 
e il registratore 


Probabilmente i peggiori 
nemici dei dispositivi 
magnetici sono l’incuria 
e la distrazione; la quasi 
totalità dei problemi che 
essi accusano può infatti 
essere di solito 
ricondotta a queste due 
cause. E pertanto 
importante eseguire una 
periodica manutenzione 
delle varie parti che 
durante il funzionamento 
delle unità vengono più 
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utilizzate e quindi 
usurate. 

Per quanto riguarda il 
drive, ci sono buone 
notizie: escludendo 
rotture e difetti costruttivi 
(peraltro estremamente 
rari), la qualità 

dei componenti 
utilizzati assicura un 
funzionamento perfetto 
dell'unità per un lungo 
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periodo senza richiedere 
alcuna manutenzione. 
Da questo lato le cose 
procedono quindi molto 
bene. 

Per quanto riguarda il 
registratore occorre 
verificare 
periodicamente che la 
calibrazione e 
l'allineamento della 
testina siano corretti, 
cioè che la velocità di 
rotazione del motore e la 
posizione della testina 


rispetto al nastro 
contenuto nella cassetta 
siano identici a quanto 
stabilito dal costruttore. 
Per questa operazione ci 
si può rivolgere a uno 
specialista, ma volendo 
la si può effettuare 
anche per conto proprio. 
Esistono infatti in 
commercio dei nastri 
mediante i quali si 
possono controllare 
automaticamente sia lo 
stato della testina che la 
velocità del motore che 
pone in rotazione la 
cartuccia. Naturalmente, 
qualora venissero 
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rilevate alcune 
irregolarità è necessario 
ricorrere allo specialista 
per rimettere a posto le 
cose. 

Il disallineamento della 
testina, soprattutto, è un 
inconveniente 
particolarmente subdolo. 
Usando il registratore 
con la testina non 
allineata, di solito tutto 
sembra infatti funzionare 
nel migliore dei modi: le 
registrazioni e le letture 
delle cassette 
avvengono normalmente, 
senza alcun errore o 
anomalia. Se si tenta 
tuttavia di leggere un 
nastro registrato da 
un'altra unità (0, 
viceversa, di leggere su 
un'altra unità una 
cassetta già registrata), 
l'operazione risulta 
impossibile. 

Questo fatto è diretta 


conseguenza della 
posizione della testina 
che indica al drive la 
presenza di registrazioni 
diverse da quelle che si 
aspettava. In un certo 
senso il lettore riconosce 
solo le proprie 
registrazioni, 
“personalizzate” dal 
disallineamento della 
testina stessa. 

Di solito un registratore 
richiede di essere 
verificato una o due 
volte all'anno. 

Ben più frequente deve 
essere invece la pulizia 
della testina. Essa va 
infatti pulita 
regolarmente, per 
eliminare ia presenza di 
polvere e di particelle di 
ossido che su di essa si 
depositano in seguito al 
contatto con il nastro. Il 
numero di puliture 
necessarie dipende 
dall'ambiente (più o 
meno polveroso) in cui il 
registratore opera e 
dall’intensità di utilizzo 
alla quale viene 
sottoposto. A questo 
scopo sono disponibili 
speciali cassette, 
appositamente ideate 
per facilitare 
l'operazione. 

Come regola generale, la 
testina del registratore 
andrebbe pulita almeno 
una volta ogni tre mesi. 
La velocità e la 
semplicità 


dell'operazione 
consigliano tuttavia un 
intervento anche più 
frequente. 

Occorre infine ricordarsi 
che anche i lettori di 
nastri magnetici sono 
meccanismi sensibili; 
quando si sposta un 
drive o un registratore si 
deve quindi, come al 
solito, cercare di evitare 
urti e vibrazioni. 

Un drive o un 
registratore ben curato 
può lavorare per anni 
senza alcun problema, 
purché si facciano le 
cose sempre con un 
minimo di attenzione (e - 
nel caso del registratore 
- di manutenzione). 


La stampante 


In quasi tutti i sistemi la 
stampante è il 
dispositivo con il 
maggior numero di parti 
meccaniche, ed è quindi 
quello con maggiori 
probabilità di guasti, 
soprattutto se impiegato 
in modo anomalo o 
scorretto. Dato che una 
stampante ha tante parti 
mobili, risente 
particolarmente di un 
uso violento. Vediamo 
come comportarsi. 

La stampante dovrebbe 
innanzitutto poggiare su 
un supporto stabile, per 
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evitare vibrazioni che ne 
disturbino il lavoro. 
Dietro e davanti alla 
stampante ci dovrebbe 
inoltre essere uno spazio 
sufficiente per poter 
accedere alla carta in 
entrata e in uscita. 

La carta va inserita 
correttamente nel 
meccanismo di trazione. 
Può sembrare una 
considerazione evidente, 
però è facile infilare la 
carta storta, provocando 
talvolta il blocco della 
stampante. Occorre 
quindi imparare a 
rispettare sempre la 
disposizione della carta. 
Un blocco della stessa è 
quasi sempre dovuto ad 
un’ostruzione fisica; di 
solito la carta si blocca 
perché i controlli sono 
regolati male, perché è 
stata inserita in modo 
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scorretto o perché si 
sono utilizzati fogli non 
idonei. 

Quando la carta si 
blocca il motore della 
stampante può bruciare: 
è quindi bene non 
assentarsi mai durante il 
funzionamento. Anche il 
nastro inchiostrato (nelle 
stampanti ad aghi e a 
margherita) deve essere 
sempre tenuto sotto 
controllo; bisogna 
saperlo inserire in modo 
corretto, facendo 
attenzione alle eventuali 
pieghe che possono 
sempre verificarsi 
durante il montaggio. 

La testina della 
stampante è una delle 
parti maggiormente 
soggette ad usura, tanto 
che è quasi normale che 
a un certo punto si 
rompa. In questo caso 
l'unica cosa da fare è 
provvedere alla 
sostituzione. 

Nel caso di guasto 
parziale o totale della 
stampante è bene 
eseguire nell'ordine 
queste operazioni: 

— controllare che la 
posizione e l'inserimento 
dei cavi di alimentazione 
e di collegamento con il 
computer siano corretti; 
— verificare tutti gli 
interruttori e i tasti di 
controllo; 

— controllare lo stato 
del fusibile; 


— controllare il 
meccanismo di stampa, 
il nastro e la carta; 

— a questo punto, se le 
cose non sono ancora 
andate a posto, far 
controllare la stampante 
presso un centro di 
assistenza tecnica. Mai 
utilizzare olio o altri 
lubrificanti, se non 
indicato espressamente 
nel manuale di istruzioni. 
Come al solito, le 
raccomandazioni del 
manuale vanno lette e 
seguite con attenzione. 
Ricorda: qualunque 
stampante funzionerà in 
modo corretto, purché 
sia regolata in maniera 
appropriata e a 
condizione che vengano 
effettuate con regolarità 
le adeguate operazioni 
di manutenzione 
richieste dall’unità. 


| cavi 
di connessione 


Ai cavi di collegamento 
vanno dedicate 
particolari cure ed 
attenzioni, essendo 
fondamentali per il buon 
funzionamento di tutto il 
sistema. 

Poiché il punto più 
debole dei cavetti risulta 
essere quello dove il 
cavo termina nello 
spinotto, occorre essere 
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molto diligenti 
nell'osservare alcune 
semplici ed elementari 
precauzioni, deducibili 
comunque anche con un 
minimo di buon senso: 
— evitare sempre e 
comunque di estrarre gli 
spinotti dalle prese 
tirandoli per il cavetto: 
questa operazione risulta 
spesso fatale per la 
continuità elettrica 
assicurata dallo spinotto; 
— cercare, nei limiti del 
possibile, di far compiere 
ai cavetti poche pieghe 
brusche; 

— limitare al massimo le 
operazioni di inserzione 
e disinserzione infatti le 
prese e gli spinotti 
subiscono nel corso di 


queste manovre una 
sollecitazione che nel 
tempo tende a 
peggiorare il contatto 
elettrico. E senz'altro 
utile ripristinare di 

tanto in tanto il migliore 
contatto, agendo con 
delicatezza sullo spinotto 
mediante una piccola 
pinza; 

— in caso di guasto la 
riparazione del cavo è 
molto semplice basta 


individuare il punto di 
rottura (di solito cedono 
sempre le saldature) e 
con un piccolo saldatore 
rimettere a posto le 
cose. Evitare riparazioni 
diverse dalla saldatura 
(tipo giunzioni con 
nastro adesivo, viti, fili 
aggiunti, ecc.); 

— controllare che il 
contatto avvenga sempre 
nel migliore dei modi, 
eliminando le eventuali 
tracce di ossido o 
sporcizia con uno 
straccetto imbevuto di 
sostanze solventi, tipo 
alcool o benzina. 


Interpreti 
e compilatori 


Quando scriviamo un 
programma in BASIC è 
facile dimenticare che in 
realtà il nostro computer 
non è in grado di capire 
quei comandi che noi gli 
impartiamo, ma può 
eseguire soltanto 
istruzioni date secondo 
una sequenza di numeri 
binari. Questi numeri, 
che costituiscono la 
lingua nativa del 
microprocessore del 
computer, vengono 
quindi forniti 
dall’interprete BASIC, 
che nel corso 


dell'esecuzione traduce 
una dopo l’altra le varie 
istruzioni componenti il 
programma. 

L'interprete BASIC nei 
confronti dell’elaboratore 
si comporta esattamente 
come un traduttore 
simultaneo, che decifra 
istantaneamente ciò che 
gli viene detto in frasi 
comprensibili ed 
eseguibili dalla CPU. 


Agli effetti pratici 
possiamo pertanto 
immaginare l'interprete 
come una specie di 
scatola magica alla 
quale vengono fornite in 
entrata le istruzioni 
BASIC e che in uscita 
risponde con ordini 
“digeribili” dall’unità 
centrale. 

In realtà l'interprete 
BASIC è anch'esso un 
programma vero e 


proprio, il cui compito è 
appunto quello di 
tradurre le istruzioni 
BASIC in istruzioni in 
linguaggio macchina. 
Per quanto veloce ed 
ottimizzato possa essere, 
il programma traduttore 
richiede tuttavia un certo 
intervallo di tempo per 
poter svolgere il proprio 
lavoro: in altre parole, la 
traduzione da istruzioni 
BASIC a istruzioni in 
linguaggio macchina 
necessita di un certo 
lavoro e di conseguenza 
introduce un certo 
rallentamento 
nell'esecuzione. 

La cosa può apparire 
alquanto ingarbugliata: 
perché ricorrere al 
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traduttore quando si 
potrebbe scrivere il 
programma direttamente 
in istruzioni eseguibili 
dal microprocessore, 
ottenendo per giunta le 
risposte molto più in 
fretta? La risposta trova 
giustificazione 
nell’enorme sforzo che 
richiede - a confronto 
della programmazione in 
BASIC - la scrittura di 
programmi in linguaggio 
macchina. 

Certamente i risultati e le 
risposte con la 
programmazione in 
assembler (così viene 
anche chiamato il 
linguaggio macchina) 
risultano molto più veloci 
e immediati, tuttavia il 
tempo necessario a 
scrivere uno stesso 
programma in assembler 
e in BASIC è nettamente 
a favore del BASIC 
(mediamente il rapporto 
è di uno a venti). 
L’interprete è quindi 
l'anello di congiunzione 
tra l'uomo e la 
macchina, cioè 
l'elemento che permette 
di realizzare una 
reciproca e perfetta 
comprensione. 

Però, come detto prima, 
dato che l'interprete 
deve leggere ogni volta 
le varie istruzioni, 
analizzarle, verificare la 
correttezza della sintassi 
ed eseguire le 
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operazioni richieste, la 
velocità di lavoro non 
può che risentirne, 
risultando notevolmente 
inferiore a quella che il 
programma potrebbe 
avere se fosse scritto 
direttamente in 
linguaggio macchina. 
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Da queste 
considerazioni risulta 
chiaro che, per quanto 
di gran lunga superiore 
a quella di qualunque 
essere umano, la 
velocità di esecuzione di 
un programma BASIC 
non potrà mai superare 
un certo livello. 

Si potrebbe pensare, per 
aumentarla, di tradurre 
manualmente il 
programma BASIC in un 
programma 
corrispondente scritto in 
linguaggio macchina, ma 
sarebbe un'operazione 
alquanto lunga e noiosa, 
da ripetersi poi ad ogni 
variazione del 
programma. 


Le operazioni 
meccaniche, lunghe, 
noiose e ripetitive sono 
proprio il genere di cose 
che possiamo far 
eseguire a un 
calcolatore: basterà 
allora scrivere (una sola 
volta) un programma che 
traduca ciascuna 
istruzione BASIC in una 


corrispondente routine in 
linguaggio macchina, e i 
nostri “problemi” 
saranno risolti. Un 
programma del genere si 
chiama compilatore 
BASIC: legge il nostro 
testo e, con pazienza, 
scrive (0, meglio, 


compila) un programma 
in linguaggio macchina 
che fa il medesimo 
lavoro. 

Il primo vantaggio di un 
programma compilato è 
l'eliminazione del 
procedimento di 
interpretazione delle 
istruzioni. Inoltre, dato 
che la sintassi viene 
controllata durante la 


compilazione, si 
risparmia ulteriore tempo 
e, tra l’altro, non c’è più 
il rischio che il 
programma contenga 
errori di sintassi non 
rilevati. 

Ma il vantaggio 
maggiore viene dal fatto 
che il compilatore, 
avendo la possibilità di 
leggere l’intero testo 
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BASIC, può eliminare le 
lente operazioni di 
ricerca delle linee (che 
l'interprete BASIC deve 
invece eseguire ad ogni 
GOTO o GOSUB) e delle 
variabili (per utilizzare 
una variabile occorre 
infatti che il traduttore 
compia un certo numero 
di operazioni, 
principalmente rivolte 
all'analisi della posizione 


occupata nella memoria 
da quella variabile). 

Per tutti questi fattori la 
velocità di un 
programma compilato è 
notevolmente superiore 
a quella dello stesso 
programma interpretato. 
Naturalmente, anche la 
compilazione ha i suoi 
svantaggi: 

— il programma, di 
solito, aumenta di 
dimensioni; 

— ci sono spesso 
istruzioni disponibili con 
l'interprete e non con il 
compilatore; 

— il lavoro di 
compilazione richiede 
tempo (anche diversi 
minuti); 

— non è possibile 
arrestare il programma 
compilato e riprenderlo 
dopo aver magari fatto 
stampare il valore di 
qualche variabile (cosa 
perfettamente lecita nel 
BASIC interpretato); 

— ogni modifica va fatta 
sul testo originario, che 
va poi nuovamente 
compilato. 

Si preferisce di solito 
scrivere il programma in 
BASIC normale (cioè 
interpretato), metterlo a 
punto e collaudarlo a 
fondo, e poi compilarlo. 
Un programma 
compilato non è più in 
BASIC, ma in linguaggio 
macchina. Di 
conseguenza non può 


essere caricato in 
memoria con un 
semplice LOAD, o fatto 
partire con RUN, ma 
occorre usare altri 
comandi. 

Da quello che abbiamo 
detto fino a questo punto 
sembrerebbe che un 
compilatore sia 
estremamente più 
vantaggioso di un 
interprete. In realtà, 
ognuno dei due presenta 
specifiche 
caratteristiche, alcune 
vantaggiose, altre 
svantaggiose, valutabili 
soltanto analizzando il 
singolo problema. Tieni 
comunque presente che 
per quanto riguarda la 
facilità e la flessibilità di 
utilizzo l'ago della 
bilancia pende 
nettamente a favore 
dell’interprete, mentre 
dal punto di vista della 
velocità di esecuzione le 
cose volgono in 
direzione del 
compilatore. 
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Rappresentazione 
dei numeri 


Finora abbiamo sempre 
evitato qualsiasi cosa 
che non fosse aritmetica 
abbastanza semplice, e 
continueremo a fare 
così. Ma sarebbe 
sbagliato non dare un 
breve sguardo alle 
capacità aritmetiche del 
computer e soprattutto 
alla rappresentazione dei 
numeri nei computer. 
L'elaborazione di un 
dato richiede infatti che 
lo stesso sia contenuto 
nella memoria 
dell’elaboratore in una 
forma immediatamente 
utilizzabile dall'unità 
centrale. Poiché l’unica 
rappresentazione 
riconoscibile dalla CPU 
è quella digitale, anche i 
numeri devono quindi 
essere espressi in tale 
forma. 

Conosci già come si fa a 
passare dalla notazione 
decimale a quella binaria 
e viceversa, e quindi non 
ci soffermeremo a 
parlare di questo 
argomento. 
Esamineremo invece 
alcuni aspetti piuttosto 
interessanti che 
emergono nell'uso 
pratico dei numeri col 
computer. 

Innanzitutto, il principale 
consiglio è quello di 
esaminare sempre con 
una certa dose di 
diffidenza qualsiasi 
numero che sia stato 


utilizzato all’interno di un 
programma. La ragione 
di questo suggerimento 
è che i numeri all’interno 
del computer, a causa 
della conversione da 
decimali a binari, 
subiscono quasi sempre 
arrotondamenti o 
troncamenti, che ne 
modificano - per quanto 
leggermente - l'esatto 
valore. Per esempio, 
nella nostra familiare 
notazione decimale ti 
ricorderai certamente 
che un numero come 
1/30 1/7 nonè in 
grado di avere 
un’espressione esatta: 
1/3=0.333333..... Noi 
diamo per scontato che 
aggiungendo al numero 
tanti 3 quanti ne 
vogliamo possiamo 
ottenere un grado di 
approssimazione 
accettabile in qualsiasi 
particolare problema. Nel 
sistema binario, allo 
stesso modo, alcuni 
numeri non possono 
essere espressi 
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esattamente; per 
esempio, nella forma 
decimale possiamo dire 
che 1/10=0.1, ma 
quando il numero viene 
cambiato in forma 
binaria non può essere 
rappresentato con la 
dovuta precisione. 

Per verificario con mano 


18 


è sufficiente che tu batta 
e faccia eseguire questo 
breve programma: 


Teoricamente tutto è 
esatto. Queste istruzioni 
costituiscono un ciclo 
che dovrebbe sottrarre 
per 10 volte la quantità 
0.1 al numero 1. La riga 
30 indica infatti al 
computer di arrestarsi 
quando la variabile | vale 
0. 

Come invece avrai 
facilmente modo di 
constatare, la condizione 
I=0 non verrà mai 
raggiunta, e il tuo 
Spectrum proseguirà 
all'infinito a sottrarre ad | 
il numero 0.1. | risultati 
delle varie operazioni 
compariranno via via 
sullo schermo, facendoti 
vedere immediatamente 
la causa di questo 
comportamento, cioè 
l'approssimazione 
introdotta nel risultato 
dai vari calcoli. 

In generale è sempre 
meglio diffidare delle 
cifre meno significative 
(cioè le cifre all'estrema 
destra) di qualsiasi 
risultato numerico: 
potrebbero essere 


conseguenza di 
imprecisioni interne. 

Per funzionare come 
volevamo il nostro 
programma avrebbe 
dovuto essere modificato 
in questa riga 


30 IF I<0.1 THEN STOP 


e tutto sarebbe andato a 
posto. 

Abbiamo quindi 
accertato che i numeri 
all’interno della memoria 
possono subire delle 
alterazioni. 

Esistono infatti dei limiti 
al numero di cifre che 
un computer è in grado 
di trattare: numeri troppo 
grandi o troppo piccoli 
devono essere quasi 
necessariamente 
arrotondati. Vediamo 
meglio questo fatto. 

Un numero molto grande 
(oppure molto piccolo) 
può essere 
rappresentato mediante 
la cosiddetta notazione 
scientifica, cioè con una 
forma abbreviata del 
numero stesso, nella 
quale si indica la 
potenza di 10 alla quale 
il numero va elevato, 
preceduta dalla lettera 
“E” (in pratica, di quante 
cifre va spostata la 
virgola). La parte a 


sinistra delle E si chiama 
mantissa, la successiva 
esponente: 


Forma normale Notazione scientifica 


1000000 1E406 
1E-07 
0.586321E-3 
0.93E+11 


0.00000001 
0.000586321 
93000000000 


Il calcolatore, al 
momento 
dell’introduzione dei 
numeri in forma normale, 


| 20 PRINT 
30 FOR I=-10 TO 10 

40 PRINT “101”; I, 10tl 
50 NEXT | 


| 10 PRINT “NUMERO”, “RAPPRESENTAZIONE” 


li trasformerà 
internamente in questo 
formato (chiamato anche 
in virgola mobile), 
consistente nel porre il 
punto decimale dopo la 
prima cifra significativa e 
aggiustare di 
conseguenza 
l'esponente. 
Naturalmente, se la 
mantissa supera una 
certa lunghezza, alcune 
cifre vanno perdute. 
Così, i due numeri 


12.00000001 I 
12.00000008 


per il tuo computer non 
sono distinguibili e 
l'informazione meno 
significativa viene 
perduta. 

Naturalmente, ci sono 
dei limiti anche per 
l'esponente. Quando il 
BASIC stampa un 
numero, lo fa in formato 
normale, a meno che 
questo comporti un 
numero di cifre 
maggiore della sua 
precisione, nel qual caso 
passa al formato 
esponenziale. Questo 
esempio ti illustrerà 
meglio quanto detto: 


Funzioni 
numeriche 


Ormai abbiamo quasi 
terminato l'esame delle 
varie funzioni disponibili 
sul tuo Spectrum: infatti, 
ce ne restano ancora 
soltanto due. Tra poco 
vedremo tuttavia come 
sia possibile, attraverso 
un utile e potente 


strumento fornito dal 
BASIC, creare e definire 
a proprio piacere 
qualsiasi altra funzione, 
che non faccia già parte 
del gruppo inserito nella 
macchina sin dalla 
fabbrica. 
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EXP 


La funzione 
esponenziale viene 
utilizzata per elevare il 
numero “e” a una certa 
potenza. Essa calcola 
cioè il valore della 
costante e (base dei 
logaritmi cosiddetti 
naturali) elevato alla 
potenza fornita 
dall’argomento 
specificato. 

Il numero e è un 
particolare valore, che 
viene definito 


matematicamente in una 
forma molto precisa, ma 
di cui il tuo Spectrum 
utilizza una 
approssimazione pari a 
2.7182818. 

Vediamola subito al 
lavoro: 


dice al computer di 
visualizzare il risultato di 
e elevato alla 1. Sullo 
schermo apparirà quindi 
il valore 2.7182818. 
L'origine di questo 
valore è abbastanza 
complessa; questo breve 
programma ti illustrerà 
tuttavia come esso 
possa essere ottenuto in 
forma approssimata: 


Sulla sinistra dello 
schermo apparirà infatti 
una serie di numeri, che 
all'aumentare di | 
tenderà ad essere 
sempre più prossima al 
valore di e fornito dalla 
funzione EXP (visibile 
sulla destra). 


Sintassi della funzione 


EXP (espressione) 


LN 


La funzione LN si utilizza 
per compiere 
l'operazione esattamente 
opposta a quella 
eseguita con EXP. 

LN calcola infatti il 
logaritmo naturale, cioè 
in base e, 
dell'argomento. 

Così, se e è il risultato di 
EXP(1), LN(e) risulterà 1. 
Gli argomenti si 
scambiano con i risultati 
e viceversa. 

Il logaritmo è una 
funzione particolarmente 
utile e preziosa in 
numerosi calcoli 
matematici, poiché 
permette di abbreviare 
conti ed operazioni, 
grazie ad alcune 
importanti proprietà di 
cui essa gode. 
Soprattutto nella tecnica 
e nei calcoli scientifici è 
quindi di basilare 
importanza disporre 
dell’uso dei logaritmi. 
Se comunque non ne 
conosci le regole di 
utilizzo, non ti 
preoccupare: visto che 
non ne hai avuto 
bisogno fino ad ora, 
forse i logaritmi non ti 
serviranno neppure in 
futuro. Nel caso tu 
comunque desiderassi 
usarli lo stesso (magari 
per generare strani 
numeri o cose del 
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genere), ricordati di non 
assegnare mai a LN un 
argomento negativo o 
nullo. Proprio come la 
funzione SQR, anche LN 
non può lavorare su 
numeri minori di zero (e 
nemmeno sullo zero). 


Sintassi della funzione 


LN (espressione) 
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DEF FN 


Capita spesso che nello 
stesso programma siano 
presenti calcoli od 
espressioni simili; in tal 
caso è possibile scriverli 
una sola volta, per poi 
richiamarli con una 
subroutine. 

Queste ultime hanno 
però lo svantaggio di 
lavorare con i nomi di 
variabili specificate nella 
routine stessa. 

Ad esempio, se 
volessimo calcolare il 
valore medio di due 
numeri, potremmo 
scrivere una cosa del 


genere: 


Questa subroutine 
fornisce però soltanto la 
media dei valori 
contenuti nelle variabili 
X e Y. 

Potrebbe darsi che nel 
nostro programma 
avessimo bisogno anche 
della media di Pe Q, 0 
di C e D. Per usare la 
subroutine dovremmo 
riassegnare i valori delle 
variabili ogni volta: 


variabili interessate, 


30 LET X=C : LET Y=D : GOSUB 100 per ottenere la radice 


quadrata di A e SQR(Z) 


In tutte le funzioni per ricavare quella di Z. 


presenti sullo Spectrum 
si fa però riferimento all 


Definendo una nuova 
funzione, potremmo 
analogamente 
specificare la variabile 
su cui fare le operazioni. 
Il BASIC consente al 
programmatore di 


definire nuove funzioni 
matematiche, utilizzabili 
in seguito come se 
facessero parte del 
linguaggio stesso. 

Per definire una nuova 
funzione bisogna 
inserire nel programma 
una istruzione del tipo 


Nel caso del nostro 
esempio la soluzione 
avrebbe quindi potuto 
essere: 


se il risultato della 
funzione è un numero, 
una lettera e un dollaro 
se il risultato è invece 
una stringa; 

— argomenti sono le 
variabili che servono per 
definire gli operandi sui 
quali interverrà la 
funzione; 

— espressione indica 
invece le operazioni che 
il computer dovrà 
eseguire per giungere al 
risultato. 

Dopo che il programma 
ha eseguito la linea 
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Da quel punto in avanti 
la funzione sarebbe stata 
considerata come 
definita e il computer 
l'avrebbe eseguita in 
tutta tranquillità. 
L'istruzione DEF FN 
consente quindi di 
definire nuove funzioni, 
oltre a quelle facenti 
parte del linguaggio vero 
e proprio. 
Approfondiamo meglio la 
sintassi da utilizzare: 

— DEF FN è una parola 
riservata, che indica 
all'elaboratore di definire 
una nuova funzione; 

— nome è la parola che 
verrà impiegata nel resto 
del programma per 
chiamare la funzione 
definita con DEF FN; 
deve essere una lettera 


la funzione M(X,Y) 
diventa quindi una 
parola riservata del 
BASIC e può essere 
usata come fosse parte 
del linguaggio. 

Per esempio: 


a ra 


vuol dire: calcola il 
valore di A, applicando 
al valore di C e S la 
funzione R definita 
prima. 


La X e la Y, che abbiamo — sono parametri formali (0 BASIC possa 


usato alla linea 10 per parametri fittizi), cioè riconoscerla, la 

definire la funzione, hanno il solo scopo di definizione della 
vengono sostituite con il —indicare dove vanno funzione deve essere 
valore della espressione impiegati gli argomenti presente nel programma. 
che segue FN M, cioè della funzione quando Qui sotto puoi trovare 
con il valore di C e S. Si questa viene chiamata. una serie di funzioni 
dice quindi che X e Y Naturalmente, perché il matematiche che non 


sono comprese nel 


BASIC standard, ma che 


è possibile definire 
mediante DEF FN nel 
momento in cui esse si 
rendessero 
eventualmente 
necessarie: 


SEC(X)=1/COS(X) Secante 
CSC(X)=1/SIN(X) Cosecante 
COT(X)=1/TAN(X) Cotangente 
ARCSIN(X)=ATN(X/SQR(-X*X+1)) Arcoseno (Seno inverso) 
ARCCOS(X)=-ANT(X/SQR(-X*X+1))+1.5708 Arcocoseno 
+ (Coseno inverso) 
ARCSEN(X)=ATN(SQR(X*X-1))H+{SGN(X)-1)*1.5708 Arcotangente 
(Tangente inversa) 
ARCCSC(X)=ATN(1/SQR(X*X-1))+(SGN(X)-1)*1.5708 Cosecante 
inversa 

ARCCOT(X)=-ATN(X)+1.5708 Cotangente inversa 
SINH(X)=(EXP(X)-EXP(-X))/2 Seno iperbolico 
COSH(X)=(EXP(X)+EXP(-X))/2 Coseno iperbolico 
TANH(X)=-EXP(-X)/(EXP(X)+EXP(-X))*2+1 Secante iperbolica 
SECH(X)=2/(EXP(X)+EXP(-X)) Tangente iperbolica 
CSCH(X)=2/(EXP(X)-EXP(-X)) Cosecante iperbolica 
COTH(X)+EXP(-X)/(EXP(X)-EXP(-X))*2+1 Cotangente iperbolica 
ARGSINH(X)=LN(X+SQR(X*X+1)) Seno iperbolico inverso 
ARGCOSH(X)=LN(X+SQR(X*X-1)) Coseno iperbolico inverso 
ARGTANH(X)=LN((1+X)/(1-x))/2 Tangente iperbolica inversa 
ARGSECH(X)\=LN((SQR(-X*X+1)+1) Secante iperbolica inversa 
ARGCSCH(X)=LN(SGN(X)*SQR(X*X+1)+1)/X  Cosecante iperbolica 
inversa 

ARGCOTH(X)\=LN((X+1)/(X-1))/2 Cotangente iperbolica inversa 
MOD(A)=INT((A/B-INT(A/B))*B+.05)*SGN(A/B) Modulo 
LN(X)=LN(X)/LN(B) Logaritmo in base B 
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Esempi 


Definisce una funzione 
(il cui nome è A) avente 
come scopo quello di 
calcolare l’area del 
cerchio di raggio R. R è 
il parametro formale. 

La linea 20 calcola l’area 
del cerchio di raggio 2. 
X costituisce invece il 
parametro reale. 


Definisce una nuova 
funzione, chiamata S, 
che esegue la stessa 
operazione della 
funzione intrinseca SIN. 


L'effetto di queste 
istruzioni sarà quindi la 
stampa di due valori 
assolutamente identici. 


Questa funzione fornisce 
come risultato un valore 
indipendente 
dall’argomento utilizzato. 
E infatti perfettamente 
lecito (sempre 
rispettando le regole 
imposte dall’istruzione) 
definire delle funzioni 
che, nonostante lo 
richiedano, non 
utilizzano l'argomento 
all’interno 
dell'espressione. In tal 
caso è addirittura 
possibile non inserire 
alcun argomento, 
lasciando così le 
parentesi vuote. 
Avremmo così potuto 


anche scrivere DEF FN 
A()=PEEK(2040)+PEEK 
(2041)*256 e il risultato 
non sarebbe cambiato. 


Anche in questo caso 
l'argomento non avrà 
alcuna influenza sul 
risultato, visto che non 
compare 
nell'espressione. Le due 
istruzioni di stampa, 
nonostante richiamino 
funzioni con argomento 
differente, produrranno 
quindi risultati identici. 


Sintassi della funzione 


Definisce una funzione 
che estrae da una 
stringa A$ i primi C 
caratteri. Naturalmente, 
visto che è una funzione 
di tipo stringa, occorre 
metterci il dollaro. 


DEF FN nome funzione (variabile [ , variabile ] ) = espressione 
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Disegno 
di un grafico 


Adesso che sappiamo 
definire a nostro piacere 
tutte le funzioni che 
vogliamo ci è possibile 
scrivere un programma 
per eseguire un'utile e 
tutto sommato divertente 
operazione: il 
tracciamento del grafico 
di una funzione. 

Per raggiungere questo 
obiettivo dobbiamo 
naturalmente riprendere 
quelle istruzioni 
elementari che avevamo 
introdotto qualche 
lezione fa, parlando della 
grafica, e che ci 
serviranno per il 
tracciamento dei singoli 
punti che comporranno 
la funzione. 

Dal punto di vista 
concettuale la scrittura 
del programma non è 
molto difficile: basta 
definire la funzione che 
desideriamo disegnare e 
procedere al 
tracciamento punto dopo 
punto. 

Un pochino più 
complicato risulta invece 
l'utilizzo del programma: 
bisognerà infatti fare 
sempre attenzione alla 
funzione che vorremo 
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disegnare. Accade 
spesso che alcune 
funzioni non siano 
definite (cioè non 
esistano) in 
corrispondenza di 
determinati valori 
dell'argomento. Per 
esempio, la funzione 
SQR non ammette 
argomenti negativi (non 
esiste la radice quadrata 
di un numero negativo!) 
e quindi qualsiasi 
tentativo di eseguire dei 
calcoli con numeri 
minori di zero incontrerà 
immediatamente lo 
sbarramento impostoci 
dal messaggio di errore. 
Questa eventuale 
limitazione è molto 
semplice da individuare 
nel caso di funzioni 
semplici (come SQR), 
mentre risulta di estrema 
difficoltà quando la 
funzione stessa si 
complica (chi è in grado 
di dire subito dove non è 
definita 
LOG(SIN(TAN(X))* 
SQR(COS(X)))?). 

Visto comunque che 
l’unica conseguenza di 
una situazione di questo 
tipo è al massimo la 
visualizzazione di un 
messaggio di errore, si 
potrà sempre (anche se 
forse non è la soluzione 
più elegante) procedere 
per tentativi. 

Ecco lo schema a 
blocchi del programma: 


Ed ecco il 
corrispondente listato: 


5 DEF FN A(X)=SIN(X) 
10 CLS 
20 PRINT:PRINT “GRAFICO FUNZIONE” 
30 INPUT “VALORE MASSIMO DELLA X”;X1MAX 
40 INPUT “VALORE MINIMO DELLA X”;X2MIN 
50 INPUT “VALORE MASSIMO DELLA Y”:Y1MAX 
60 INPUT “VALORE MINIMO DELLA Y”:Y2MIN 
70 IF X1MAX<=X2MIN OR Y1MAX<=Y2MIN THEN RUN 
80 GOSUB 1000:REM FATTORI DI SCALA 
90 LET SCALA=176/(Y1MAX-Y2MIN) 
100 LET X=X2MIN-XSCALA 
110 LET C=-1 
120 REM 
130 REM TRACCIA LA FUNZIONE 
140 REM 
150 LET C=C+1 
160 LET X=X+XSCALA 
170 LET Y=SK+(FN A(X)*SCALA) 
180 IF Y>175 OR Y<0 THEN GO TO 200 
190 PLOT C,Y 
200 IF C<255 THEN GOTO 150 
210 REM 
220 REM GRAFICO ESEGUITO 
230 REM 
240 GO TO 240 
1000 REM 
1010 REM CALCOLA | FATTORI DI SCALA 
1020 REM 
1030 LET XSCALA=ABS((X1MAX-X2MIN)/256) 
1040 LET YSCALA=ABS((Y1MAX-Y2MIN)/176) 
1050 IF Y2MIN>=0 THEN LET SK=0:RETURN 
1060 IF YIMAX<=0 THEN LET SK=175:RETURN 
1070 LET C=-1 
1080 LET Y=Y2MIN-YSCALA 
1090 LET C=C+1 
1100 LET Y=Y+YSCALA 
1110 IF Y>=0 THEN LET SK=C:RETURN 
1120 GOTO 1090 
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PROGRAMMAZIONE 


Particolari difficoltà non 
ne esistono: l’unico fatto 
degno di nota è il 
calcolo dei fattori di 
scala, necessario per 
proporzionare il grafico 
alle dimensioni del 
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nostro immaginario 
foglio quadrettato, 
rappresentato dal nostro 
schermo video. Tali 
fattori dipenderanno dai 
valori massimi e minimi 
che tu assegnerai alla X 
e alla Y (cioè all’ascissa 
e all’ordinata). 

Gli abbondanti commenti 
e l’uso frequente delle 
subroutine rendono il 
programma abbastanza 
semplice da leggere e 
da capire. 

Per cambiare la funzione 
da tracciare l’unica 
modifica necessaria è 
quella di sostituire alla 
linea 5 l’espressione 
della vecchia funzione 
(che attualmente è 
SIN(X)) con la definizione 
della nuova. 

A titolo di possibile 
miglioramento prova 
come esercizio a far 
tracciare - prima del 
grafico vero e proprio - 
anche i due assi 
cartesiani presi come 
sistema di riferimento 
(attenzione che bisogna 
considerare varie 
possibilità!). 


Programma 
finanziario 


Il programma seguente 
fa uso della formula: 


T=LN(CF/C)/LN (I) 


per calcolare il tempo 
necessario affinché un 
determinato capitale 
iniziale (CI) possa 
diventare uguale al 
capitale finale (CF) ad un 


certo tasso di interesse 
(1). 
Nota la funzione definita 
nella prima linea il cui 
compito è quello di 


eseguire 
l'arrotondamento del 
tempo calcolato. 


10 DEF FNA (N) = INT (N + .5) i 
20 INPUT “CI ="; Cl “CF ="; CF“ =" 1 
30 LETI= 1 +1/100 : 

40 LETT=LN(CF/CI)/LNI 
50 PRINT FN A (T) 

60 GO TO 20 


La funzione definita nel programma seguente esegue i calcoli necessari per 
visualizzare una parabola. Definiscine una per ottenere la rappresentazione di 
un grafico diverso. 


10 CLS 
20 GO SUB 300 
30 DEF FN X (Y) = Y * Y/2.6 
35 PRINT “PARABOLA” 
40 FORI=-9T09 
50 PRINT AT | + 10, FN X (1); “*” 
60 NEXT | 
70 GO SUB 500 
80 STOP : 
300 FORI=1 TO 10 ‘ 
310 PRINT “I” 
320 NEXT | 
330 FORI=1 TO 32 
340 PRINT “—”; |; 
350 NEXT | 
355 PRINT 
360 FORI=1 TO 10 
370 PRINT “I” 
380 NEXT | 
390 PRINT AT 0, 0; 
400 RETURN 
500 LET A$ = INKEY$ 
510 IF A$ = “” THEN GO TO 500 
520 RETURN 
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